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A METHOD OF CALCULATING INTERNAL SIGNALS FOR USE IN A MAP 

ALGORITHM 

FIELD OF THE INVENTION 

This invention relates to the method for calculating internal signals used in a MAP algorithm, 
more particularly, but not exclusively, for use in the max-log-MAP (maximum a posteriori) 
algorithm. 

BACKGROUND OF THE INVENTION 

The max-log-MAP decoding algorithm is a simplified version of the MAP decoding 
algorithm, which is also known as the BCJR decoding algorithm. The max-log-MAP is used to 
decode a convolutional encoder. It is one of the more popular soft output decoding methods. 

A main application of the max-log-MAP decoder is in the decoding of turbo codes, which are 
generated using two parallel concatenated convolutional encoders. Two max-log-MAP 
decoders are used as component decoders in the turbo decoder. Today, turbo codes have 
become established as an important method of channel coding in the third generation wireless 
mobile communication technical specification. However, as time progresses and demand for 
high data rate communication increases, the turbo decoder is burdened with the task of 
performing with very high processing speed. Improving the speed of the component decoders 
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of the turbo decoder, i.e. the max-log-MAP decoders, is the key to increasing turbo decoding 
speed. 

. The conventional max-log-MAP algorithm will now be described. 

At the input of the max-log-MAP decoder are two kinds of received signals: received 
systematic symbols X and received coded symbols Y. A third possible kind of input signal is a 
lambda X signal from the previous max-log-MAP decoder output if iterative decoding (turbo 
decoding) is applied. These signals are used to compute lambda, or in the case of turbo 
decoding, new lambda values. Several important internal signals of the max-log-MAP are 
defined: a, P, and Y. 

a and p are computed recursively - i.e. the computation of the internal signal a or p at a 
symbol sequence t needs the value of the internal signal from the previous, for a, or following, 
for p, symbol sequence (t-1 or t+1). 

There are two types of Y values: Y° is associated with the probability of a systematic symbol 
X being bit 0, while Y 1 is associated with the probability of the systematic symbol being bit 1 . 
Y is computed using X, Y and the lambda from the previous max-log-MAP decoder output, 
denoted by Ap. 

Signal Y is calculated according to a trellis diagram. Table 1 gives and example of how YO and 
Yl, given states m, are calculated in an 8-state recursive systematic convolutional (RSC) 
encoder with the following transfer function: [1, gi(D)/g 0 (D)] where g 0 (D)=l+D 2 +D 3 and 
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gi=l+D+D 3 . In the above polynomials, the Ds describe a set of different Hamming distances 
(with respect to all zeros) that can be obtained from a convolutional encoder. Note that, 1 
actually referes to D° (Hamming distance of 0). Here, an 8-state RSC encoder is taken as an 
example. In fact, m can be other states, such as 16 states or 32 states, depending on the 
application. 
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Table 1: Example of Y values for states m 



The a for symbol sequence t and states m (total eight different states) is calculated using a and 
T at M from two different states (m° and m 1 ). This is done by first computing an 
unnormalized signal a 

a t (m) = max-of-2 { a^m 0 ) + Y° t _i(m°) , c^m 1 ) + Y^iCm 1 ) } (1) 

Using the example of the same RSC encoder used in Table 1, Table 2 gives the values of m° 
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and m 1 corresponding to m, wherein states m° and m 1 are selected arbitrarily from eight 
different states m. 

The initial values a 0 (m) are set to appropriate constants. Usually, ao(0) is set to 0 and {ao(l)> 
So(2),—> ao(7)} are set to a large negative number, for example, -128. 
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Table 2: Example of m and m values corresponding to m for a computation 
After all eight states are computed, all a values are normalized by subtracting a constant A t . 
a t (m) = a,(m) - A t (2) 
A t is a function of a t which can be obtained in several ways. Some of them are 

A, = max-of-8 { a t (m) } me{0 ,i 7 > (3a) 

A, = ( max-of-8 { a,(m) } me{ o,i,...,7> + min-of-8 { a t (m) } m6{ o,i,...,7> ) / 2 (3b) 
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A t = a t (0) (3c) 

Similarly, p is computed vising information from different states (m° and m ! ) and the symbol 
sequence t+1 , and using Y from states m at sequence t. 

First, the unnormalized J3 is computed 

g t (m) = max-of-2 { p t+ i(mV Y° t (m), Pt + i(m 1 )+ Y^m) } (4) 

Table 3 gives the values of m° and m 1 corresponding to m, using the same RSC encoder. 

The initial value Pl+i(0), where L is the frame size, is usually set to 0, while {JL+iOX 
gL+i(2),...,pL+i(7)} are usually set to a large negative number, for example, -128. 
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Table 3: Example of m and m values corresponding to m for p computation 
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After all 8 states are computed, all g values are normalized by subtracting a constant B t which 
is obtained in the similar way as A t 



Lambda is computed using a, (3 and Y of all states. The m and m states for p are the same as 



given in Table 3. 

%t= max-of-8 { a t (m) + Y\(m) + Pt+iCm 1 ) } me{0 ,i,...,7> 



As can be seen from the equations, two or more symbols of a or p cannot be computed in 
parallel, and therefore must be computed in sequence. However, the sequential computation of 
a can run in parallel with the sequential computation of p. Therefore, as a and p have exactly 
the same complexity and are independent of each other, from this point, the a and P 
computations are referred as a single entity called a/p computations, for convenience sake. 

Lambda computations, however, are not independent of a/p computations. The lambda 
computation for symbol sequence t cannot begin until a and p of symbol sequence t are 
computed. 

Looking at the algorithm for computing a/p for symbol sequence t (equations (1) - (5)), it can 
be seen that the algorithm can be divided into four dependent sequential stages. In other 
words, one stage cannot begin until the previous has been completed. For example, to compute 
a for symbol sequence t, the four stages Sl(t) - S4(t) are 



Pt(m) = fit(m)-B t 



(5) 



- max-of-8 { a t (m) + Y° t (m) + p t+ i(m°) } me {o,i,...,7> 



(6) 
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Sl(t): Compute Y° M (m°) and YViOn 1 ) using Table 1 
S2(t): Compute a t (m) using equation (1) 
S3(t): Compute A t using one of the equations (3a), (3b), (3c) 
S4(t): Compute a t (m) using equation (2) 

It is possible to implement pipelining by starting S2 for the next symbol sequence t+1 after 
S4(t). This is because Sl(t) is independent of any stage at any symbol sequence. Figure 1 
illustrates an example of the timeline of such an implementation, with the assumption that the 
length of time taken for the stages SI - S4 follows the proportion of T1:T2:T3:T4 = 
1:1:1.5:0.5. 

In general, the length of time taken to complete the stages given L number of symbols is 
T = Tl + L (T2 + T3 + T4) (7) 

Using the prior art, the pipelining implementation is limited by the normalization computation 
(S3 and S4). In other words, part of the cpmputation (referring to S2) of symbol sequence t+1 
can begin only after the normalization computation in symbol sequence t is completed. 

One way to improve this is to forgo the normalization computation for a few symbols 
(normalization can never be completely eliminated because it is needed to prevent overflow), 
but this would produce different results and slightly increase the number of bits which are set 
aside for the internal signals. 
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It is an object of the invention to provide a method of calculating decoding signals that can 
improve the pipelining implementation. 

SUMMARY OF THE INVENTION 

In accordance with the present invention, there is provided a method of calculating internal 
signals for use in a MAP algorithm, comprising the steps of: obtaining first decoding signals 
by processing received systematic arid received encoded symbols of each symbol sequence of 
a received signal; obtaining unnormalized second decoding signals for the current symbol 
sequence by processing the first decoding signals of the previous sequence and second 
decoding signals of the previous sequence; obtaining unnormalized third decoding signals for 
the current symbol sequence by processing the first decoding signals of the current sequence 
and third decoding signals of the next sequence; normalizing the unnormalized second and 
third decoding signals; and wherein at least one of said second decoding signals of the 
previous sequence and said third decoding signals of the next sequence are unnormalised. 

Preferably, said first decoding signals are of two types, one type being associated with the 
probability of a said systematic symbol being 0 and the other type being associated with the 
probability of a said systematic symbol being 1 . 

Preferably, the step of obtaining current unnormalized second decoding signals is 
implemented by: 

fit(m) = max-of-2 { a t .,(m°) + Y 0 t _,(m°) , at-Km 1 ) + Y^.^m 1 ) } - A M 
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where at(m) are said current unnormalized second decoding signals for states m, at-i(m°) and ct t . 
lOm 1 ) are respectively said prior unnormalized second decoding signals, for states m° and m 1 , 
Y° t .i(ni 0 ) and Y^.iCm 1 ) are respectively said two types of said prior first decoding signals for 
states m° and m 1 , A t -i is a second decoding signal constant for a previous time period, wherein 
said states m° and m 1 are selected from said states m. 

Preferably, the step of normalizing said second decoding signal comprises the step of 

calculating: 

at(m) = a t (m)-A t 

where, a t (m) are said current second decoding signals for states m, a t (m) are said 
unnormalized second decoding signals for states m, A t is a second decoding signal constant for 
the current period. 

Preferably, the step of obtaining current unnormalized second decoding signals is 
implemented by: 

a t (m) = max-of-2 { a t -i(m°) + Y° t _i(m 0 ) , at-^m 1 ) + YYiCm 1 ) } 

where a t (m) are said current unnormalized second decoding signals for states m, g t .|(m°) and a t - 
\(m l ) are respectively said prior unnormalized second decoding signals, for states m° and m 1 , 
Y°t.i(m°) and Y 1 t .i(m 1 ) are respectively said two types of said prior first decoding signals for 
states m° and m 1 , wherein said states m° and m 1 are selected from said states m. 

Preferably, said step of normalizing said current second decoding signal comprises the step of 
calculating: 
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a t (m) = a t (m) -A,- (Aj + A 2 + ... + A M ) 

where, a t (m) is said current second decoding signals for states m, a t (m) is said unnormalized 
second decoding signals for states m, and Ai, A 2 , A t -i and A t are respectively second 
decoding signal constants for the first to current periods. 

Preferably, said second decoding signal constant for the current period A t is one of: 
A t = max-of-all states { a t (m) } 

A t = ( max-of-all states { a t (m) } + min-of-all states { a t (m) }) / 2 
At-a t (0) 

where a t (m) is said unnormalized second decoding signals for states m. 

The method of the present invention preferably further comprises a step of setting the initial 
values of said unnormalized second decoding signals to selected constants. 

Preferably, the step of obtaining said unnormalized third decoding signals is implemented by: 
fit(m) = max-of-2 { fi t+ i(mV T° t (m), fi t+ i(m , )+ Y 1 t (m) } - B t ., 

where 0t(m) are the current unnormalized third decoding signals for states m, j3 t +i(m 0 )) and 
j3 t +i(m ! ) are respectively two values of the future unnormalized third decoding signals for 
states m° and states m 1 , Y° t (m) and T^m) are respectively said two types of said current first 
decoding signals for states m, B t _i is a third decoding signal constant for a prior period and 
said states m° and m 1 are selected from said states m. 

Preferably, said step of normalizing said third decoding signals is implemented by calculating 



• u 

Mm) = fit(m)-B t 

where, p t (m) are the current third decoding signals for states m, £t(m) are the current 
unnormalized third decoding signals for states m, and B t is the current third decoding signal 
constant. 



Preferably, the step of obtaining said unnormalized third decoding signals is implemented by: 
fi t (m) = max-of-2 { £ t+ i(m°)+ T° t (m), &+i(m l )+ Y^Cm) } 

where £t(ni) are the current unnormalized third decoding signals for states m, J} t +i(ni 0 ) and 
gt+iCm 1 ) are respectively two values of the future unnormalized third decoding signal for 
states mO and ml, Y° t (m) and T ! t(m) are respectively said two types of the current first 
decoding signals, wherein said states m° and m 1 are selected from said states m. 

Said step of normalizing said third decoding signal may comprise the step of calculating 
Pt(m) = fit(m) - B t - (Bi + B 2 + ... + B M ) 

where, p t (m) are the current third decoding signal for states m, |3t(m) are unnormalized third 
decoding signal for states m, and Bi, B2, B t .i and B t are respectively third decoding signal 
constants for the first to current periods; 

The third decoding signal constant B t for the current period may be : 
B t = max-of-all states { j3 t (m) } 

B t = ( max-of-all states { fi t (ni) } + min-of-all states { fit(m) }) / 2 
B t = fi t (0) 
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Where J3t(m) are the current unnormalized third decoding signals for states m. 

The method of the present invention preferably further comprises a step of setting the initial 
values of said unnormalized third decoding signals to selected constants. 

Preferably, both of said second decoding signals of the previous sequence and said third 
decoding signals of the next sequence are unnormalised. 

Preferably, the calculation of the internal signals is pipelined whereby the calculation for the 
next symbol sequence is commenced once the unnormalized signals for the current symbol 
sequence have been calculated. 

The described embodiment of the invention is a modification of the calculations of decoding 
signals a and/or p in algorithm to allow for an improved pipelining implementation and 
allows S2(t+1) to be independent of the normalization in t, and can begin computation as soon 
as S2(t) is completed. The described embodiment also retains the same final values of the 
interned signals (the values after S4) as the prior art. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Embodiments of the invention will now be described, by way of example, with reference to 
the accompanying drawings, in which: 
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Fig. 1 illustrates a prior art timing diagram of the four stages of a/p computation for three 
symbols in a pipelining implementation. 

Fig. 2 illustrates a timing diagram of the four stages of a/p computation for three symbols in a 
pipelining implementation according to a first embodiment of the invention. 

Fig. 3 illustrates a timing diagram of the four stages of ot/p computation for three symbols in a 
pipelining implementation according to a second embodiment of the invention. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS OF THE 
INVENTION 

The embodiments of the invention use modified max-log-MAP algorithms and a first 
embodiment will now be described. 

In the modified algorithm, the computations for a/p are modified so that pipelining 
implementation can be faster than that of the prior art. The main feature is to make the 
computation of a/g of symbol sequence t+1 independent of the normalization of a/0 of symbol 
sequence t. 

Equation (1) is modified so that a t (m) is computed using unnormalized values a t .i(m) instead 

of normalized values a t -i(m), and a normalized constant A t .i is added. 

a t (m) = max-of-2 { a t .,(m°) + Y° M (m 0 ) , a^Cm 1 ) + Y^m 1 ) } - A t -i (8) 

Equation (2) remains the same. 
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a t (m) = a t (m) - A t 



(9) 



Similarly, equations (4) and (5) are modified to 



g t (m) = max-of-2 { fi t+ i(mV Y° t (m), ^(m 1 )* Y\(m) } - B t _, 



(10) 



Pt(m) =fit(m)-B t 



(11) 



The final values of a t and p t are still exactly the same as the prior art. 

Following these modifications, the four dependent sequential stages described in the prior art 
are now slightly different. For example, to compute a for symbol sequence t, the four stages of 
the modified equations Slm(t) - S4m(t) are 

Slm(t): Compute Y° t -i(m 0 ) and YYiOn 1 ) using Table 1 

S2m(t): Compute a t (m) using equation (8) (Am being known from the previous iteration) 
S3m(t): Compute A t using one of the equations (3a), (3b), (3c) 
S4m(t): Compute a t (m) using equation (9) 

Compared with the prior art, the length of time taken for these modified stages is almost the 
same. SI and Sim take exactly the same computation time, and so do the pair S3 and S3m and 
the pair S4 and S4m. The length of time taken for stage S2m is slightly increased compared 
with S2, because S2m further subtracts the constant Am. 



As in the prior art, it is possible to implement pipelining by starting S2 for the next symbol 
sequence t+1 after S4(t). This is because Sl(t) is independent of any stage at any symbol 
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sequence. Figure 1 illustrates an example of the timeline of such an implementation, with the 
assumption that the length of time taken for the stages SI - S4 follows the ratio 1:1:1.5:0.5. 

However, the pipelining implementation can now be improved because S2m(t+1) can begin 
after S2m(t). This is because the normalization computations have been deferred. Figure 2 
illustrates an example of the timeline of the improved pipelining implementation according to 
the first embodiment of the present invention, with the assumption that the length of time 
taken for the stages Sim - S4m follows the proportion of Tlm:T2m:T3m:T4m = 1:1.5:1 .5:0.5, 
which is the same as the assumption given in the prior art description except for the second 
stage. 

Stage 2 can start immediately after the end of the previous stage 2. Therefore, in general, the 
length of time taken to complete the stages given L number of symbols is 

Tm = Tim + T2m + (T3m + T4m) + (L-l)x (T2m + T3m + T4m - T3m - T4m) 

= Tim + L x T2m + T3m + T4m (12) 

By comparing with the prior art, we can substitute Tl = Tim, T2 = T2m/1.5, T3 = T3m, and 
T4 = T4m, and obtain 

T = Tim + L (T2m/1 .5 + T3m + T4m) (13) 



The number of times of improvement in speed compared with the prior art is 



16 

T/Tm = (Tlm + L(T2m/L5+T3m + T4m))/(Tlm + LxT2m + T3m + T4m) (14) 



For there to be an improvement in speed, the ratio T / Tm must be more than one. Further 
simplification of T / Tm > 1 yields 

L > 1 + T2m / (3 x T3m + 3 x T4m - T2m) (15) 

It can be seen from equation (15) that there will be an improvement in speed as long as the 
frame size is not one, as T2m / (3 x T3m + 3x T4m - T2m) is likely to be less than one. 
Practically, this means that there will be an improvement at any frame size. 

Using the example of Tlm:T2m:T3m:T4m = 1:1.5:1.5:0.5 in equation (14), the number of 
times of improvement in speed approaches 2 for large L. 

However, the improvement should be smaller in the case where S3 is computed using a more 
complex method such as in equations (3a) and (3b), because a relatively small T3 produces a 
small T / Tm ratio. 

In a second embodiment, the algorithm described as the first embodiment can be slightly 
modified and still retain the properties of independent normalization and same final values as 
now described. 

Equation (8) and (9) can be rearranged as 



St(m) = max-of-2 { a M (m°) + T° M (m°) , a,-i(m ! ) + Y , t -i(m 1 ) } 



(16) 
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and 



a t (m) = a t (m) - A t - (Ai + A 2 + ... + A M ) 



(17) 



This shortens the procedure in (8) and makes the procedure in (9) longer, but the effect is the 
same. 

Similarly, equations (10) and (11) can be rearranged as 



The stages Sim and S3m are still the same, but S2m and S4m are slightly different. For 
example, for a computation of second embodiment, the four stages are 

Slm 2 (t): Compute Y° t _i(m°) and Y i t .i(m 1 ) using Table 1 

S2m2(t): Compute a t (m) using equation (16) 

S3m 2 (t): Compute A t using one of the equations (3a), (3b), (3c) 

S4m 2 (t): Compute a t (m) using equation (17), and store (Ai + A 2 + ... + A t ) for future use (in 



fi t (m) = max-of-2 { fit + i(m°)+ Y° t (m), g t+ i(m 1 )+ T ! t (m) } 



(18) 



p t (m) = fit(m) - B t - (B, + B 2 + ... + B M ) 



(19) 



the next symbol sequence t+1) 



Compared with the prior art, the length of time taken for these modified stages is almost the 
same. SI and Slm 2 take exactly the same computation time, and so do the pair S2 and S2m 
and the pair S3 and S3m. S4m 2 is only two times longer than S4 because instead of subtracting 



18 

one constant, S4ni2 subtracts two constants (the second one is the stored value from the 
previous S4m2 symbol). 



In general, the length of time taken to complete the stages given L number of symbols is 

Tm = Tim + T2m + T3m + Lx T4m (20) 

By comparing with the prior art, we can substitute Tl = Tim, T2 = T2m, T3 = T3m, and T4 
T4m/2, and obtain 

T = Tim + L (T2m + T3m + T4m/2) (21) 

The number of times of improvement in speed compared with the prior art is 

T/Tm = ( Tim + L (T2m + T3m + T4m/2) ) / (Tim + T2m + T3m + L x T4m) (22) 

For there to be an improvement in speed, the ratio T / Tm must be more than one. Further 
simplification of T / Tm > 1 yields 

L > 1 + (T2m/2) / (T2m + T3m - T4m/2) (23) 



It can be seen from equation (23) that there will be an improvement in speed as long as the 
frame size, L, is not one, as the ratio (T2m/2) / (T2m + T3m - T4m/2) is likely to be less than 
one. Practically, this means that there will be an improvement at any frame size. 
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Figure 3 illustrates an example of the timeline of the improved pipelining implementation 
according to the second embodiment of the present invention. In Fig. 3, it is assumed that the 
length of time taken for the stages Sim - S4m follows the proportion of Tlm:T2m:T3m:T4m 
= 1:1:1.5:1. Using the above proportion in equation (22), the number of times of improvement 
in speed approaches 3 for large L. 

However, the improvement should be larger in the case where S3 is computed using a more 
complex method such as in equations (3a) and (3b), because a relatively large T3 produces a 
large T / Tm ratio. 

This algorithm may still significantly faster than the prior art. 

The modification of a/p computation in the max-log-MAP algorithm as explained in the first 
and second embodiments can also be applied to a BCJR (full-MAP) algorithm, or a log-MAP 
algorithm. Furthermore, the algorithm may be applied to the calculation of a or p or both. 

In summary, a method for calculating decoding signals in a MAP algorithm, such as max-log- 
MAP algorithm, has been disclosed. The above-described embodiments of the invention are 
intended to be illustrative only. Numerous alternative embodiments may be devised by those 
skilled in the art without departing from the scope of the following claims. 



CLAIMS: 
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1. A method of calculating internal signals for use in a MAP algorithm, comprising the steps 
of: 

obtaining first decoding signals by processing received systematic and received encoded 
symbols of each symbol sequence of a received signal; 

obtaining unnormalized second decoding signals for the current symbol sequence by 
processing the first decoding signals of the previous sequence and second decoding signals of 
the previous sequence; 

obtaining unnormalized third decoding signals for the current symbol sequence by 
processing the first decoding signals of the current sequence and third decoding signals of the 
next sequence; 

normalizing the unnormalized second and third decoding signals; and 
wherein at least one of said second decoding signals of the previous sequence and said 
third decoding signals of the next sequence are unnormalised. 

2. A method according to claim 1, wherein said first decoding signals are of two types, one 
type being associated with the probability of a said systematic symbol being 0 and the other 
type being associated with the probability of a said systematic symbol being 1 . 

3. A method according to claim 2, wherein the step of obtaining current unnormalized second 
decoding signals is implemented by: 

a t (m) = max-of-2 { a,,(m°) + Y° t .i(m°) , a ul (m l ) + Y't-Km 1 ) } - A t _, 
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where a t (m) are said current unnormalized second decoding signals for states m, a t -i(m°) and a t . 
i(m l ) are respectively said prior unnormalized second decoding signals, for states m° and m 1 , 
Y°M(m°) and Y^.iOn 1 ) are respectively said two types of said prior first decoding signals for 
states m° and m 1 , A t -i is a second decoding signal constant for a previous time period, wherein 
said states m° and m 1 are selected from said states m. 

4. A method according to claim 3, wherein the step of normalizing said second decoding 
signal comprises the step of calculating: 

a t (m) = a t (m) - A t 

where, a t (m) are said current second decoding signals for states m, a t (m) are said 
unnormalized second decoding signals for states m, A t is a second decoding signal constant for 
the current period. 

5. A method according to claim 2, wherein the step of obtaining current unnormalized second 
decoding signals is implemented by: 

a t (m) = max-of-2 { a^m 0 ) + Y 0 t -i(m 0 ) , at-iCm 1 ) + Y^Km 1 ) } 

where a t (m) are said current unnormalized second decoding signals for states m, a t -i(m°) and a t - 
i(m ! ) are respectively said prior unnormalized second decoding signals, for states m° and m 1 , 
Y°t-i(m°) and YViOn 1 ) are respectively said two types of said prior first decoding signals for 
states m° and m 1 , wherein said states m° and m 1 are selected from said states m. 

6. A method according to claim 5, wherein said step of normalizing said current second 
decoding signal comprises the step of calculating: 
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a t (m) = a t (m) - A t - (Ai + A 2 + ... + A t .i) 

where, a t (m) is said current second decoding signals for states m, a t (m) is said unnormalized 
second decoding signals for states m, and Ai, A2, A t -j and A t are respectively second 
decoding signal constants for the first to current periods. 

7. A method according to claim 4 or claim 6, wherein said second decoding signal constant for 
the current period A t is one of: 

A t = max-of-all states { a t (m) } 

A t = ( max-of-all states { a t (m) } + min-of-all states { a t (m) }) / 2 
A t = a t (0) 

where a t (m) is said unnormalized second decoding signals for states m. 

8. A method according to any one of claims 3-7, further comprising a step of setting the initial 
values of said unnormalized second decoding signals to selected constants. 

9. A method according to any one of claims 2 to 8, wherein the step of obtaining said 
unnormalized third decoding signals is implemented by: 

fi t (m) - max-of-2 { &+i(m°)+ T° t (m), fit^m 1 )* Y\(m) } - B t ., 

where g t (m) are the current unnormalized third decoding signals for states m, g t +i(m 0 )) and 
fit+iCm 1 ) are respectively two values of the future unnormalized third decoding signals for 
states m° and states m 1 , Y° t (m) and T\(m) are respectively said two types of said current first 
decoding signals for states m, B t .i is a third decoding signal constant for a prior period and 
said states m° and m 1 are selected from said states m. 
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10. A method according to claim 9, wherein said step of normalizing said third decoding 
signals is implemented by calculating 

Pt(m) = fi t (m)-B t 

where, p t (m) are the current third decoding signals for states m, g t (m) are the current 
unnormalized third decoding signals for states m, and B t is the current third decoding signal 
constant. 

1 1 . A method according to any one of claims 2 to 8, wherein the step of obtaining said 
unnormalized third decoding signals is implemented by: 

fit(m) = max-of-2 { fi t+ i(m°)+ Y° t (m), gt+Km 1 )* Y^m) } 

where J3 t ( m ) are the current unnormalized third decoding signals for states m, J3 t +i(m°) and 
gt+iCm 1 ) are respectively two values of the future unnormalized third decoding signal for 
states m° and m 1 , T° t (m) and Y\(m) are respectively said two types of the current first 
decoding signals, wherein said states m° and m 1 are selected from said states m. 

12. A method according to claim 11, wherein said step of normalizing said third decoding 
signal comprises the step of calculating 

p t (m) = fi t (m) - B t - (B, + B 2 + ... + B t -i) 

where, Pt(m) are the current third decoding signal for states m, j3 t (m) are unnormalized third 
decoding signal for states m, and Bi, B2, B t -i and B t are respectively third decoding signal 
constants for the first to current periods. 
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13. A method according to claim 10 or claim 12, wherein the third decoding signal constant B t 
for the current period is : 

B t = max-of-all states { J3 t ( m ) } 

B t = ( max-of-all states { g t (m) } + min-of-all states { j3 t (m) }) / 2 
B t = fit(0) 

Where J3 t (m) are the current unnormalized third decoding signals for states m. 

14. A method according to claims 9-13, wherein further comprising a step of setting the initial 
values of said unnormalized third decoding signals to selected constants. 

15. A method according to any one of the preceding claims wherein both of said second 
decoding signals of the previous sequence and said third decoding signals of the next sequence 
are unnormalised. 

16. A method according to any one of the preceding claims wherein the calculation of the 
internal signals is pipelined whereby the calculation for the next symbol sequence is 
commenced once the unnormalized signals for the current symbol sequence have been 
calculated. 
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A METHOD OF CALCULATING INTERNAL SIGNALS FOR USE IN A MAP 

ALGORITHM 

A method of calculating internal signals for use in a MAP algorithm is disclosed, comprising 
the steps of: 

obtaining first decoding signals by processing received systematic and received encoded 
symbols of each symbol sequence of a received signal; 

obtaining unnormalized second decoding signals for the current symbol sequence by 
processing the first decoding signals of the previous sequence and second decoding signals of 
the previous sequence; 

obtaining unnormalized third decoding signals for the current symbol sequence by 
processing the first decoding signals of the current sequence and third decoding signals of the 
next sequence; 

normalizing the unnormalized second and third decoding signals; and 
wherein at least one of said second decoding signals of the previous sequence and said 
third decoding signals of the next sequence are unnormalised. 
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